package com.xb.cloud.product.service.business.model;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import com.xb.cloud.common.model.PageParam;

public class CategoryExample extends PageParam{
    protected String orderByClause;

    protected boolean distinct;

    protected List<Criteria> oredCriteria;

    public CategoryExample() {
        oredCriteria = new ArrayList<Criteria>();
    }

    public void setOrderByClause(String orderByClause) {
        this.orderByClause = orderByClause;
    }

    public String getOrderByClause() {
        return orderByClause;
    }

    public void setDistinct(boolean distinct) {
        this.distinct = distinct;
    }

    public boolean isDistinct() {
        return distinct;
    }

    public List<Criteria> getOredCriteria() {
        return oredCriteria;
    }

    public void or(Criteria criteria) {
        oredCriteria.add(criteria);
    }

    public Criteria or() {
        Criteria criteria = createCriteriaInternal();
        oredCriteria.add(criteria);
        return criteria;
    }

    public Criteria createCriteria() {
        Criteria criteria = createCriteriaInternal();
        if (oredCriteria.size() == 0) {
            oredCriteria.add(criteria);
        }
        return criteria;
    }

    protected Criteria createCriteriaInternal() {
        Criteria criteria = new Criteria();
        return criteria;
    }

    public void clear() {
        oredCriteria.clear();
        orderByClause = null;
        distinct = false;
    }

    protected abstract static class GeneratedCriteria {
        protected List<Criterion> criteria;

        protected GeneratedCriteria() {
            super();
            criteria = new ArrayList<Criterion>();
        }

        public boolean isValid() {
            return criteria.size() > 0;
        }

        public List<Criterion> getAllCriteria() {
            return criteria;
        }

        public List<Criterion> getCriteria() {
            return criteria;
        }

        protected void addCriterion(String condition) {
            if (condition == null) {
                throw new RuntimeException("Value for condition cannot be null");
            }
            criteria.add(new Criterion(condition));
        }

        protected void addCriterion(String condition, Object value, String property) {
            if (value == null) {
                throw new RuntimeException("Value for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value));
        }

        protected void addCriterion(String condition, Object value1, Object value2, String property) {
            if (value1 == null || value2 == null) {
                throw new RuntimeException("Between values for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value1, value2));
        }

        public Criteria andIdIsNull() {
            addCriterion("id is null");
            return (Criteria) this;
        }

        public Criteria andIdIsNotNull() {
            addCriterion("id is not null");
            return (Criteria) this;
        }

        public Criteria andIdEqualTo(Long value) {
            addCriterion("id =", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotEqualTo(Long value) {
            addCriterion("id <>", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThan(Long value) {
            addCriterion("id >", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThanOrEqualTo(Long value) {
            addCriterion("id >=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThan(Long value) {
            addCriterion("id <", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThanOrEqualTo(Long value) {
            addCriterion("id <=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdIn(List<Long> values) {
            addCriterion("id in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotIn(List<Long> values) {
            addCriterion("id not in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdBetween(Long value1, Long value2) {
            addCriterion("id between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotBetween(Long value1, Long value2) {
            addCriterion("id not between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andCompanyIdIsNull() {
            addCriterion("company_id is null");
            return (Criteria) this;
        }

        public Criteria andCompanyIdIsNotNull() {
            addCriterion("company_id is not null");
            return (Criteria) this;
        }

        public Criteria andCompanyIdEqualTo(Long value) {
            addCriterion("company_id =", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdNotEqualTo(Long value) {
            addCriterion("company_id <>", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdGreaterThan(Long value) {
            addCriterion("company_id >", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdGreaterThanOrEqualTo(Long value) {
            addCriterion("company_id >=", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdLessThan(Long value) {
            addCriterion("company_id <", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdLessThanOrEqualTo(Long value) {
            addCriterion("company_id <=", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdIn(List<Long> values) {
            addCriterion("company_id in", values, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdNotIn(List<Long> values) {
            addCriterion("company_id not in", values, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdBetween(Long value1, Long value2) {
            addCriterion("company_id between", value1, value2, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdNotBetween(Long value1, Long value2) {
            addCriterion("company_id not between", value1, value2, "companyId");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdIsNull() {
            addCriterion("category_parent_id is null");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdIsNotNull() {
            addCriterion("category_parent_id is not null");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdEqualTo(Long value) {
            addCriterion("category_parent_id =", value, "categoryParentId");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdNotEqualTo(Long value) {
            addCriterion("category_parent_id <>", value, "categoryParentId");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdGreaterThan(Long value) {
            addCriterion("category_parent_id >", value, "categoryParentId");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdGreaterThanOrEqualTo(Long value) {
            addCriterion("category_parent_id >=", value, "categoryParentId");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdLessThan(Long value) {
            addCriterion("category_parent_id <", value, "categoryParentId");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdLessThanOrEqualTo(Long value) {
            addCriterion("category_parent_id <=", value, "categoryParentId");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdIn(List<Long> values) {
            addCriterion("category_parent_id in", values, "categoryParentId");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdNotIn(List<Long> values) {
            addCriterion("category_parent_id not in", values, "categoryParentId");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdBetween(Long value1, Long value2) {
            addCriterion("category_parent_id between", value1, value2, "categoryParentId");
            return (Criteria) this;
        }

        public Criteria andCategoryParentIdNotBetween(Long value1, Long value2) {
            addCriterion("category_parent_id not between", value1, value2, "categoryParentId");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafIsNull() {
            addCriterion("category_is_leaf is null");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafIsNotNull() {
            addCriterion("category_is_leaf is not null");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafEqualTo(Byte value) {
            addCriterion("category_is_leaf =", value, "categoryIsLeaf");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafNotEqualTo(Byte value) {
            addCriterion("category_is_leaf <>", value, "categoryIsLeaf");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafGreaterThan(Byte value) {
            addCriterion("category_is_leaf >", value, "categoryIsLeaf");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafGreaterThanOrEqualTo(Byte value) {
            addCriterion("category_is_leaf >=", value, "categoryIsLeaf");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafLessThan(Byte value) {
            addCriterion("category_is_leaf <", value, "categoryIsLeaf");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafLessThanOrEqualTo(Byte value) {
            addCriterion("category_is_leaf <=", value, "categoryIsLeaf");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafIn(List<Byte> values) {
            addCriterion("category_is_leaf in", values, "categoryIsLeaf");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafNotIn(List<Byte> values) {
            addCriterion("category_is_leaf not in", values, "categoryIsLeaf");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafBetween(Byte value1, Byte value2) {
            addCriterion("category_is_leaf between", value1, value2, "categoryIsLeaf");
            return (Criteria) this;
        }

        public Criteria andCategoryIsLeafNotBetween(Byte value1, Byte value2) {
            addCriterion("category_is_leaf not between", value1, value2, "categoryIsLeaf");
            return (Criteria) this;
        }

        public Criteria andCategoryNameIsNull() {
            addCriterion("category_name is null");
            return (Criteria) this;
        }

        public Criteria andCategoryNameIsNotNull() {
            addCriterion("category_name is not null");
            return (Criteria) this;
        }

        public Criteria andCategoryNameEqualTo(String value) {
            addCriterion("category_name =", value, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryNameNotEqualTo(String value) {
            addCriterion("category_name <>", value, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryNameGreaterThan(String value) {
            addCriterion("category_name >", value, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryNameGreaterThanOrEqualTo(String value) {
            addCriterion("category_name >=", value, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryNameLessThan(String value) {
            addCriterion("category_name <", value, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryNameLessThanOrEqualTo(String value) {
            addCriterion("category_name <=", value, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryNameLike(String value) {
            addCriterion("category_name like", value, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryNameNotLike(String value) {
            addCriterion("category_name not like", value, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryNameIn(List<String> values) {
            addCriterion("category_name in", values, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryNameNotIn(List<String> values) {
            addCriterion("category_name not in", values, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryNameBetween(String value1, String value2) {
            addCriterion("category_name between", value1, value2, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryNameNotBetween(String value1, String value2) {
            addCriterion("category_name not between", value1, value2, "categoryName");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeIsNull() {
            addCriterion("category_code is null");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeIsNotNull() {
            addCriterion("category_code is not null");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeEqualTo(String value) {
            addCriterion("category_code =", value, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeNotEqualTo(String value) {
            addCriterion("category_code <>", value, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeGreaterThan(String value) {
            addCriterion("category_code >", value, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeGreaterThanOrEqualTo(String value) {
            addCriterion("category_code >=", value, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeLessThan(String value) {
            addCriterion("category_code <", value, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeLessThanOrEqualTo(String value) {
            addCriterion("category_code <=", value, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeLike(String value) {
            addCriterion("category_code like", value, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeNotLike(String value) {
            addCriterion("category_code not like", value, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeIn(List<String> values) {
            addCriterion("category_code in", values, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeNotIn(List<String> values) {
            addCriterion("category_code not in", values, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeBetween(String value1, String value2) {
            addCriterion("category_code between", value1, value2, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryCodeNotBetween(String value1, String value2) {
            addCriterion("category_code not between", value1, value2, "categoryCode");
            return (Criteria) this;
        }

        public Criteria andCategoryDescIsNull() {
            addCriterion("category_desc is null");
            return (Criteria) this;
        }

        public Criteria andCategoryDescIsNotNull() {
            addCriterion("category_desc is not null");
            return (Criteria) this;
        }

        public Criteria andCategoryDescEqualTo(String value) {
            addCriterion("category_desc =", value, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryDescNotEqualTo(String value) {
            addCriterion("category_desc <>", value, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryDescGreaterThan(String value) {
            addCriterion("category_desc >", value, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryDescGreaterThanOrEqualTo(String value) {
            addCriterion("category_desc >=", value, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryDescLessThan(String value) {
            addCriterion("category_desc <", value, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryDescLessThanOrEqualTo(String value) {
            addCriterion("category_desc <=", value, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryDescLike(String value) {
            addCriterion("category_desc like", value, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryDescNotLike(String value) {
            addCriterion("category_desc not like", value, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryDescIn(List<String> values) {
            addCriterion("category_desc in", values, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryDescNotIn(List<String> values) {
            addCriterion("category_desc not in", values, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryDescBetween(String value1, String value2) {
            addCriterion("category_desc between", value1, value2, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryDescNotBetween(String value1, String value2) {
            addCriterion("category_desc not between", value1, value2, "categoryDesc");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordIsNull() {
            addCriterion("category_keyword is null");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordIsNotNull() {
            addCriterion("category_keyword is not null");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordEqualTo(String value) {
            addCriterion("category_keyword =", value, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordNotEqualTo(String value) {
            addCriterion("category_keyword <>", value, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordGreaterThan(String value) {
            addCriterion("category_keyword >", value, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordGreaterThanOrEqualTo(String value) {
            addCriterion("category_keyword >=", value, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordLessThan(String value) {
            addCriterion("category_keyword <", value, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordLessThanOrEqualTo(String value) {
            addCriterion("category_keyword <=", value, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordLike(String value) {
            addCriterion("category_keyword like", value, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordNotLike(String value) {
            addCriterion("category_keyword not like", value, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordIn(List<String> values) {
            addCriterion("category_keyword in", values, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordNotIn(List<String> values) {
            addCriterion("category_keyword not in", values, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordBetween(String value1, String value2) {
            addCriterion("category_keyword between", value1, value2, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andCategoryKeywordNotBetween(String value1, String value2) {
            addCriterion("category_keyword not between", value1, value2, "categoryKeyword");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceIsNull() {
            addCriterion("is_must_invoice is null");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceIsNotNull() {
            addCriterion("is_must_invoice is not null");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceEqualTo(Byte value) {
            addCriterion("is_must_invoice =", value, "isMustInvoice");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceNotEqualTo(Byte value) {
            addCriterion("is_must_invoice <>", value, "isMustInvoice");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceGreaterThan(Byte value) {
            addCriterion("is_must_invoice >", value, "isMustInvoice");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceGreaterThanOrEqualTo(Byte value) {
            addCriterion("is_must_invoice >=", value, "isMustInvoice");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceLessThan(Byte value) {
            addCriterion("is_must_invoice <", value, "isMustInvoice");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceLessThanOrEqualTo(Byte value) {
            addCriterion("is_must_invoice <=", value, "isMustInvoice");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceIn(List<Byte> values) {
            addCriterion("is_must_invoice in", values, "isMustInvoice");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceNotIn(List<Byte> values) {
            addCriterion("is_must_invoice not in", values, "isMustInvoice");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceBetween(Byte value1, Byte value2) {
            addCriterion("is_must_invoice between", value1, value2, "isMustInvoice");
            return (Criteria) this;
        }

        public Criteria andIsMustInvoiceNotBetween(Byte value1, Byte value2) {
            addCriterion("is_must_invoice not between", value1, value2, "isMustInvoice");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumIsNull() {
            addCriterion("show_guide_num is null");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumIsNotNull() {
            addCriterion("show_guide_num is not null");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumEqualTo(Byte value) {
            addCriterion("show_guide_num =", value, "showGuideNum");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumNotEqualTo(Byte value) {
            addCriterion("show_guide_num <>", value, "showGuideNum");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumGreaterThan(Byte value) {
            addCriterion("show_guide_num >", value, "showGuideNum");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumGreaterThanOrEqualTo(Byte value) {
            addCriterion("show_guide_num >=", value, "showGuideNum");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumLessThan(Byte value) {
            addCriterion("show_guide_num <", value, "showGuideNum");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumLessThanOrEqualTo(Byte value) {
            addCriterion("show_guide_num <=", value, "showGuideNum");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumIn(List<Byte> values) {
            addCriterion("show_guide_num in", values, "showGuideNum");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumNotIn(List<Byte> values) {
            addCriterion("show_guide_num not in", values, "showGuideNum");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumBetween(Byte value1, Byte value2) {
            addCriterion("show_guide_num between", value1, value2, "showGuideNum");
            return (Criteria) this;
        }

        public Criteria andShowGuideNumNotBetween(Byte value1, Byte value2) {
            addCriterion("show_guide_num not between", value1, value2, "showGuideNum");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayIsNull() {
            addCriterion("max_return_day is null");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayIsNotNull() {
            addCriterion("max_return_day is not null");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayEqualTo(Integer value) {
            addCriterion("max_return_day =", value, "maxReturnDay");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayNotEqualTo(Integer value) {
            addCriterion("max_return_day <>", value, "maxReturnDay");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayGreaterThan(Integer value) {
            addCriterion("max_return_day >", value, "maxReturnDay");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayGreaterThanOrEqualTo(Integer value) {
            addCriterion("max_return_day >=", value, "maxReturnDay");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayLessThan(Integer value) {
            addCriterion("max_return_day <", value, "maxReturnDay");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayLessThanOrEqualTo(Integer value) {
            addCriterion("max_return_day <=", value, "maxReturnDay");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayIn(List<Integer> values) {
            addCriterion("max_return_day in", values, "maxReturnDay");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayNotIn(List<Integer> values) {
            addCriterion("max_return_day not in", values, "maxReturnDay");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayBetween(Integer value1, Integer value2) {
            addCriterion("max_return_day between", value1, value2, "maxReturnDay");
            return (Criteria) this;
        }

        public Criteria andMaxReturnDayNotBetween(Integer value1, Integer value2) {
            addCriterion("max_return_day not between", value1, value2, "maxReturnDay");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayIsNull() {
            addCriterion("max_exchange_day is null");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayIsNotNull() {
            addCriterion("max_exchange_day is not null");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayEqualTo(Integer value) {
            addCriterion("max_exchange_day =", value, "maxExchangeDay");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayNotEqualTo(Integer value) {
            addCriterion("max_exchange_day <>", value, "maxExchangeDay");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayGreaterThan(Integer value) {
            addCriterion("max_exchange_day >", value, "maxExchangeDay");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayGreaterThanOrEqualTo(Integer value) {
            addCriterion("max_exchange_day >=", value, "maxExchangeDay");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayLessThan(Integer value) {
            addCriterion("max_exchange_day <", value, "maxExchangeDay");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayLessThanOrEqualTo(Integer value) {
            addCriterion("max_exchange_day <=", value, "maxExchangeDay");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayIn(List<Integer> values) {
            addCriterion("max_exchange_day in", values, "maxExchangeDay");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayNotIn(List<Integer> values) {
            addCriterion("max_exchange_day not in", values, "maxExchangeDay");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayBetween(Integer value1, Integer value2) {
            addCriterion("max_exchange_day between", value1, value2, "maxExchangeDay");
            return (Criteria) this;
        }

        public Criteria andMaxExchangeDayNotBetween(Integer value1, Integer value2) {
            addCriterion("max_exchange_day not between", value1, value2, "maxExchangeDay");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameIsNull() {
            addCriterion("category_search_name is null");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameIsNotNull() {
            addCriterion("category_search_name is not null");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameEqualTo(String value) {
            addCriterion("category_search_name =", value, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameNotEqualTo(String value) {
            addCriterion("category_search_name <>", value, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameGreaterThan(String value) {
            addCriterion("category_search_name >", value, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameGreaterThanOrEqualTo(String value) {
            addCriterion("category_search_name >=", value, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameLessThan(String value) {
            addCriterion("category_search_name <", value, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameLessThanOrEqualTo(String value) {
            addCriterion("category_search_name <=", value, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameLike(String value) {
            addCriterion("category_search_name like", value, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameNotLike(String value) {
            addCriterion("category_search_name not like", value, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameIn(List<String> values) {
            addCriterion("category_search_name in", values, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameNotIn(List<String> values) {
            addCriterion("category_search_name not in", values, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameBetween(String value1, String value2) {
            addCriterion("category_search_name between", value1, value2, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategorySearchNameNotBetween(String value1, String value2) {
            addCriterion("category_search_name not between", value1, value2, "categorySearchName");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelIsNull() {
            addCriterion("category_level is null");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelIsNotNull() {
            addCriterion("category_level is not null");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelEqualTo(Byte value) {
            addCriterion("category_level =", value, "categoryLevel");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelNotEqualTo(Byte value) {
            addCriterion("category_level <>", value, "categoryLevel");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelGreaterThan(Byte value) {
            addCriterion("category_level >", value, "categoryLevel");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelGreaterThanOrEqualTo(Byte value) {
            addCriterion("category_level >=", value, "categoryLevel");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelLessThan(Byte value) {
            addCriterion("category_level <", value, "categoryLevel");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelLessThanOrEqualTo(Byte value) {
            addCriterion("category_level <=", value, "categoryLevel");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelIn(List<Byte> values) {
            addCriterion("category_level in", values, "categoryLevel");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelNotIn(List<Byte> values) {
            addCriterion("category_level not in", values, "categoryLevel");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelBetween(Byte value1, Byte value2) {
            addCriterion("category_level between", value1, value2, "categoryLevel");
            return (Criteria) this;
        }

        public Criteria andCategoryLevelNotBetween(Byte value1, Byte value2) {
            addCriterion("category_level not between", value1, value2, "categoryLevel");
            return (Criteria) this;
        }

        public Criteria andCategorySortIsNull() {
            addCriterion("category_sort is null");
            return (Criteria) this;
        }

        public Criteria andCategorySortIsNotNull() {
            addCriterion("category_sort is not null");
            return (Criteria) this;
        }

        public Criteria andCategorySortEqualTo(Integer value) {
            addCriterion("category_sort =", value, "categorySort");
            return (Criteria) this;
        }

        public Criteria andCategorySortNotEqualTo(Integer value) {
            addCriterion("category_sort <>", value, "categorySort");
            return (Criteria) this;
        }

        public Criteria andCategorySortGreaterThan(Integer value) {
            addCriterion("category_sort >", value, "categorySort");
            return (Criteria) this;
        }

        public Criteria andCategorySortGreaterThanOrEqualTo(Integer value) {
            addCriterion("category_sort >=", value, "categorySort");
            return (Criteria) this;
        }

        public Criteria andCategorySortLessThan(Integer value) {
            addCriterion("category_sort <", value, "categorySort");
            return (Criteria) this;
        }

        public Criteria andCategorySortLessThanOrEqualTo(Integer value) {
            addCriterion("category_sort <=", value, "categorySort");
            return (Criteria) this;
        }

        public Criteria andCategorySortIn(List<Integer> values) {
            addCriterion("category_sort in", values, "categorySort");
            return (Criteria) this;
        }

        public Criteria andCategorySortNotIn(List<Integer> values) {
            addCriterion("category_sort not in", values, "categorySort");
            return (Criteria) this;
        }

        public Criteria andCategorySortBetween(Integer value1, Integer value2) {
            addCriterion("category_sort between", value1, value2, "categorySort");
            return (Criteria) this;
        }

        public Criteria andCategorySortNotBetween(Integer value1, Integer value2) {
            addCriterion("category_sort not between", value1, value2, "categorySort");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlIsNull() {
            addCriterion("category_icon_url is null");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlIsNotNull() {
            addCriterion("category_icon_url is not null");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlEqualTo(String value) {
            addCriterion("category_icon_url =", value, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlNotEqualTo(String value) {
            addCriterion("category_icon_url <>", value, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlGreaterThan(String value) {
            addCriterion("category_icon_url >", value, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlGreaterThanOrEqualTo(String value) {
            addCriterion("category_icon_url >=", value, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlLessThan(String value) {
            addCriterion("category_icon_url <", value, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlLessThanOrEqualTo(String value) {
            addCriterion("category_icon_url <=", value, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlLike(String value) {
            addCriterion("category_icon_url like", value, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlNotLike(String value) {
            addCriterion("category_icon_url not like", value, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlIn(List<String> values) {
            addCriterion("category_icon_url in", values, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlNotIn(List<String> values) {
            addCriterion("category_icon_url not in", values, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlBetween(String value1, String value2) {
            addCriterion("category_icon_url between", value1, value2, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andCategoryIconUrlNotBetween(String value1, String value2) {
            addCriterion("category_icon_url not between", value1, value2, "categoryIconUrl");
            return (Criteria) this;
        }

        public Criteria andIsEnabledIsNull() {
            addCriterion("is_enabled is null");
            return (Criteria) this;
        }

        public Criteria andIsEnabledIsNotNull() {
            addCriterion("is_enabled is not null");
            return (Criteria) this;
        }

        public Criteria andIsEnabledEqualTo(Byte value) {
            addCriterion("is_enabled =", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledNotEqualTo(Byte value) {
            addCriterion("is_enabled <>", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledGreaterThan(Byte value) {
            addCriterion("is_enabled >", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledGreaterThanOrEqualTo(Byte value) {
            addCriterion("is_enabled >=", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledLessThan(Byte value) {
            addCriterion("is_enabled <", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledLessThanOrEqualTo(Byte value) {
            addCriterion("is_enabled <=", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledIn(List<Byte> values) {
            addCriterion("is_enabled in", values, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledNotIn(List<Byte> values) {
            addCriterion("is_enabled not in", values, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledBetween(Byte value1, Byte value2) {
            addCriterion("is_enabled between", value1, value2, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledNotBetween(Byte value1, Byte value2) {
            addCriterion("is_enabled not between", value1, value2, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsDeletedIsNull() {
            addCriterion("is_deleted is null");
            return (Criteria) this;
        }

        public Criteria andIsDeletedIsNotNull() {
            addCriterion("is_deleted is not null");
            return (Criteria) this;
        }

        public Criteria andIsDeletedEqualTo(Byte value) {
            addCriterion("is_deleted =", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedNotEqualTo(Byte value) {
            addCriterion("is_deleted <>", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedGreaterThan(Byte value) {
            addCriterion("is_deleted >", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedGreaterThanOrEqualTo(Byte value) {
            addCriterion("is_deleted >=", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedLessThan(Byte value) {
            addCriterion("is_deleted <", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedLessThanOrEqualTo(Byte value) {
            addCriterion("is_deleted <=", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedIn(List<Byte> values) {
            addCriterion("is_deleted in", values, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedNotIn(List<Byte> values) {
            addCriterion("is_deleted not in", values, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedBetween(Byte value1, Byte value2) {
            addCriterion("is_deleted between", value1, value2, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedNotBetween(Byte value1, Byte value2) {
            addCriterion("is_deleted not between", value1, value2, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdIsNull() {
            addCriterion("create_user_id is null");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdIsNotNull() {
            addCriterion("create_user_id is not null");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdEqualTo(Long value) {
            addCriterion("create_user_id =", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdNotEqualTo(Long value) {
            addCriterion("create_user_id <>", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdGreaterThan(Long value) {
            addCriterion("create_user_id >", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdGreaterThanOrEqualTo(Long value) {
            addCriterion("create_user_id >=", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdLessThan(Long value) {
            addCriterion("create_user_id <", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdLessThanOrEqualTo(Long value) {
            addCriterion("create_user_id <=", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdIn(List<Long> values) {
            addCriterion("create_user_id in", values, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdNotIn(List<Long> values) {
            addCriterion("create_user_id not in", values, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdBetween(Long value1, Long value2) {
            addCriterion("create_user_id between", value1, value2, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdNotBetween(Long value1, Long value2) {
            addCriterion("create_user_id not between", value1, value2, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameIsNull() {
            addCriterion("create_user_name is null");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameIsNotNull() {
            addCriterion("create_user_name is not null");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameEqualTo(String value) {
            addCriterion("create_user_name =", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameNotEqualTo(String value) {
            addCriterion("create_user_name <>", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameGreaterThan(String value) {
            addCriterion("create_user_name >", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameGreaterThanOrEqualTo(String value) {
            addCriterion("create_user_name >=", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameLessThan(String value) {
            addCriterion("create_user_name <", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameLessThanOrEqualTo(String value) {
            addCriterion("create_user_name <=", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameLike(String value) {
            addCriterion("create_user_name like", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameNotLike(String value) {
            addCriterion("create_user_name not like", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameIn(List<String> values) {
            addCriterion("create_user_name in", values, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameNotIn(List<String> values) {
            addCriterion("create_user_name not in", values, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameBetween(String value1, String value2) {
            addCriterion("create_user_name between", value1, value2, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameNotBetween(String value1, String value2) {
            addCriterion("create_user_name not between", value1, value2, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIsNull() {
            addCriterion("create_time is null");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIsNotNull() {
            addCriterion("create_time is not null");
            return (Criteria) this;
        }

        public Criteria andCreateTimeEqualTo(Date value) {
            addCriterion("create_time =", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotEqualTo(Date value) {
            addCriterion("create_time <>", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeGreaterThan(Date value) {
            addCriterion("create_time >", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("create_time >=", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeLessThan(Date value) {
            addCriterion("create_time <", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeLessThanOrEqualTo(Date value) {
            addCriterion("create_time <=", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIn(List<Date> values) {
            addCriterion("create_time in", values, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotIn(List<Date> values) {
            addCriterion("create_time not in", values, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeBetween(Date value1, Date value2) {
            addCriterion("create_time between", value1, value2, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotBetween(Date value1, Date value2) {
            addCriterion("create_time not between", value1, value2, "createTime");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdIsNull() {
            addCriterion("update_user_id is null");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdIsNotNull() {
            addCriterion("update_user_id is not null");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdEqualTo(Long value) {
            addCriterion("update_user_id =", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdNotEqualTo(Long value) {
            addCriterion("update_user_id <>", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdGreaterThan(Long value) {
            addCriterion("update_user_id >", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdGreaterThanOrEqualTo(Long value) {
            addCriterion("update_user_id >=", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdLessThan(Long value) {
            addCriterion("update_user_id <", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdLessThanOrEqualTo(Long value) {
            addCriterion("update_user_id <=", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdIn(List<Long> values) {
            addCriterion("update_user_id in", values, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdNotIn(List<Long> values) {
            addCriterion("update_user_id not in", values, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdBetween(Long value1, Long value2) {
            addCriterion("update_user_id between", value1, value2, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdNotBetween(Long value1, Long value2) {
            addCriterion("update_user_id not between", value1, value2, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameIsNull() {
            addCriterion("update_user_name is null");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameIsNotNull() {
            addCriterion("update_user_name is not null");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameEqualTo(String value) {
            addCriterion("update_user_name =", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameNotEqualTo(String value) {
            addCriterion("update_user_name <>", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameGreaterThan(String value) {
            addCriterion("update_user_name >", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameGreaterThanOrEqualTo(String value) {
            addCriterion("update_user_name >=", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameLessThan(String value) {
            addCriterion("update_user_name <", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameLessThanOrEqualTo(String value) {
            addCriterion("update_user_name <=", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameLike(String value) {
            addCriterion("update_user_name like", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameNotLike(String value) {
            addCriterion("update_user_name not like", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameIn(List<String> values) {
            addCriterion("update_user_name in", values, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameNotIn(List<String> values) {
            addCriterion("update_user_name not in", values, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameBetween(String value1, String value2) {
            addCriterion("update_user_name between", value1, value2, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameNotBetween(String value1, String value2) {
            addCriterion("update_user_name not between", value1, value2, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeIsNull() {
            addCriterion("update_time is null");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeIsNotNull() {
            addCriterion("update_time is not null");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeEqualTo(Date value) {
            addCriterion("update_time =", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeNotEqualTo(Date value) {
            addCriterion("update_time <>", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeGreaterThan(Date value) {
            addCriterion("update_time >", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("update_time >=", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeLessThan(Date value) {
            addCriterion("update_time <", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeLessThanOrEqualTo(Date value) {
            addCriterion("update_time <=", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeIn(List<Date> values) {
            addCriterion("update_time in", values, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeNotIn(List<Date> values) {
            addCriterion("update_time not in", values, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeBetween(Date value1, Date value2) {
            addCriterion("update_time between", value1, value2, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeNotBetween(Date value1, Date value2) {
            addCriterion("update_time not between", value1, value2, "updateTime");
            return (Criteria) this;
        }
    }

    public static class Criteria extends GeneratedCriteria {

        protected Criteria() {
            super();
        }
    }

    public static class Criterion {
        private String condition;

        private Object value;

        private Object secondValue;

        private boolean noValue;

        private boolean singleValue;

        private boolean betweenValue;

        private boolean listValue;

        private String typeHandler;

        public String getCondition() {
            return condition;
        }

        public Object getValue() {
            return value;
        }

        public Object getSecondValue() {
            return secondValue;
        }

        public boolean isNoValue() {
            return noValue;
        }

        public boolean isSingleValue() {
            return singleValue;
        }

        public boolean isBetweenValue() {
            return betweenValue;
        }

        public boolean isListValue() {
            return listValue;
        }

        public String getTypeHandler() {
            return typeHandler;
        }

        protected Criterion(String condition) {
            super();
            this.condition = condition;
            this.typeHandler = null;
            this.noValue = true;
        }

        protected Criterion(String condition, Object value, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.typeHandler = typeHandler;
            if (value instanceof List<?>) {
                this.listValue = true;
            } else {
                this.singleValue = true;
            }
        }

        protected Criterion(String condition, Object value) {
            this(condition, value, null);
        }

        protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.secondValue = secondValue;
            this.typeHandler = typeHandler;
            this.betweenValue = true;
        }

        protected Criterion(String condition, Object value, Object secondValue) {
            this(condition, value, secondValue, null);
        }
    }
}